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TECHNICAL FIELD 

The present invention relates to an index preparing 
method and apparatus for utilizing a calculator to perform search, 
classification, tendency analysis, and the like of vector data with 
respect to a vector database as a group of vector data (N- 
dimensional real vector usually called "characteristic vector" 
obtained by arranging N real numbers indicating data 
characteristics) prepared by extracting respective data 
characteristics from various electronically accumulated databases 
(data groups) of text information, image information, sound 
information, questionnaire result, sales result (POS) and other 
data. The present invention also relates to a similar vector 
searching method and apparatus for using the index prepared by the 
aforementioned method and apparatus to efficiently search a vector 
similar to a designated vector. 

BACKGROUND ART 

In recent years, with formation of a database of 
multimedia information of text, image, sound, and the like, and 
spread of a POS system, and the like, a technique for efficiently 
executing search, classification, tendency analysis, and the like 
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of a vector database of an assembly of several hundreds of 
thousands to several millions of pieces of vector data of several 
tens to several hundreds of dimensions has intensively been 
researched/developed in computer systems such as a multimedia 
5 database systen and a data mining system. 

For example, with a newspaper article database, for the 
database in which a large number of pieces of newspaper article 
data are accumulated, a dictionary of w words is used to extract an 
appearance frequency f k of each word k in the dictionary from each 

10 newspaper article, and each newspaper article is represented as a 

set of an identification number i and W-dimensional real vector (f ir 
f 2 , — , fj . This vector is converted by a main component 
analyzing technique, and main N (N < W) components are obtained and 
used as vector data* An inner product of the vector data 

15 corresponding to the designated newspaper article, and a vector 
corresponding to another newspaper article in the database is 
calculated, the newspaper article having the vector with a largest 
inner product is obtained, and high-precision similar article 
search is possible. U.S. Patent Wo. 4839853 discloses a document 

20 searching method in which such vector data is used. 

Moreover, with a photograph database, each photograph 
data is subjected to a two-dimensional Fourier transform with 
respect to the database in which a large number of pieces of 
photograph image data are accumulated, and main N Fourier 

25 components are obtained as the vector data by extracting f fc and 
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representing each photograph data by a set of a photograph number i 
and N-dimens ional real vector (f ir f 2/ — / . A distance (size 
of a difference between two vectors) between the vector data 
corresponding to the designated photograph and the vector 
5 corresponding to another photograph data in the database is 

calculated, and photograph data having the vector with a smallest 
distance is obtained, so that high-precision similar photograph 
search is possible. Furthermore, for example, several pieces of 
typical photograph data belonging to each of different categories 

10 such as "portrait", "landscape photograph", and "close-up 

photography of a flower" are presented as classification conditions, 
an average characteristic vector of each category is calculated, 
and the category of the characteristic vector with a shortest 
distance is assigned to each photograph data vector, so that 

15 remaining photograph data can automatically be classified into the 
aforementioned three categories. 

Since an efficient similar searching method of a 
remarkably high-dimensional vector of several tens to several 
hundreds of dimensions is necessary for such use, various methods 

20 have been researched. For example, a high-dimensional vector index 
preparing method and similarity searching method using a 
multidimensional searching (SR) tree are disclosed in "The SR-tree: 
An Index Structure for High-Dimensional Nearest Neighbor Queries" 
Proceedings of the SIGMOD '97, ACM (1997) by Norio Katayaroa and 

25 Shinichi Satoh. Moreover, a high-dimensional vector index 
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preparing method and similarity searching method based on Boronoi 
division are disclosed in "Near Neighbor Search in Large Metric 
Spaces", Proceedings of the VLDB'95, Morgan-Kaufman Publishers 
(1995) by Sergey Br in* Furthermore, a high-dimens ional vector 
5 index preparing method and similarity searching method based on 
data partitioning technique called "pyramid technique" are 
disclosed in "the Pyramid-Technique: towards Breaking the Curse of 
Dimesnsionarity'' , Proceedings of the SIGMOD'98, ACM (1998) by Stefan 
Berchtold, Christian Bohm and Hans Kriegel. 
10 However, these conventional vector index preparing method 

and similar vector searching methods have problems that any one of 
the following four conditions is not satisfied, and the methods 
cannot broadly be applied to broad-range applications. 

1) High-speed search is possible even when the vector is 
15 of several hundreds of dimensions . 

2) During similarity searching, either one of two types 
of similarity of the distance between the vectors and the vector 
inner product can be selected. 

3) The similarity searching of "obtaining L vectors 

20 having most similarity" can be performed. Furthermore, even when L 
is relatively large (several .tens to several hundreds), a search 
processing is not excessively delayed. 

4) A similarity search range such as "inner product of 
0.6 or more" can be designated. 

25 5) A calculation amount required for index preparing is 
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in a practical range (i.e., the index can be prepared in a time 
proportional to a vector data amount n f or a n*log(n) time) . 

Concretely, the method using the SR tree does not satisfy 
the above 1), 2), the method based on Boronoi division does not 
5 satisfy 2), 5), and the method using the pyramid technique does not 
satisfy 2), 3). 

A vector index preparing method, similar vector searching 
method, and apparatuses for the methods of the present invention 
solve these problems of the conventional technique. A high- 

10 dimensional vector is decomposed to a plurality of partial vectors, 
and a direction and size of each partial vector are represented and 
recorded by a set of a belonging region number defined by a center 
vector, an angle (declination) formed with the center vector, and a 
norm division indicating a norm. Therefore, a search object range 

15 of the vector index can precisely be limited even for any query 
vector. When a difference between a partial inner product lower 
limit value (upper limit value of a partial square distance) and an 
actual partial inner product (partial square distance) is 
accumulated, an efficient search result by a branch limiting 

20 technique can be defined. Therefore, the vector index preparing 
method and similar vector searching method are provided which 
satisfies all of the above 1) to 4) and which can be applied to a 
broad range application. 

TO solve the aforementioned problem, according to a first 

25 aspect of the present invention, there are provided a vector index 



preparing method and apparatus comprising: means for calculating a 
partial vector; means for tabulating a norm distribution and 
preparing a norm division table; means for calculating a region 
number; means for tabulating a declination distribution and 
preparing a declination division table; means for calculating a 
norm division number; means for calculating a declination division 
number; means for calculating index data; and means for 
constituting an index. Thereby, even when the vector is of several 
hundreds of dimensions, a high-speed search is possible with 
respect to a vector database having unclear direction and norm 
distribution. During similarity searching, either one of two types 
of similarity of a distance between vectors and a vector inner 
product can be selected. The similarity search of a type such that 
"most similar L vectors are obtained" can be performed. 
Furthermore, even when L is relatively large (several tens to 
several hundreds), a search processing is not excessively delayed. 
A similarity search range such as "inner product of 0.6 or more" 
can be designated. Additionally, a calculation amount required for 
index preparation is in a practical range. Such vector index can 
effectively be prepared. 

Moreover, in addition to the first aspect, the vector 
index preparing method and apparatus according to a second aspect 
of the present invention further comprise means for calculating a 
component division number. Thereby, in addition to the effect of 
the first aspect, an effect is produced that a calculation error by 



quantization of a component is minimized and a capacity of the 
vector index to be prepared can remarkably be reduced. 

Furthermore, according to a third aspect of the present 
invention, there are provided a similar vector searching method and 
apparatus comprising: means for calculating a partial query 
condition; means for preparing a search object range; means for 
searching an index; means for calculating an inner product 
difference upper limit; and means for determining a similarity 
search result. An accumulated value of a partial inner product 
difference is calculated and used as a clue to a similarity search. 
Thereby, even when the vector is of several hundreds of dimensions, 
a high-speed search is possible with respect to a vector database. 
The similarity search of the type such that "most similar L vectors 
are obtained" can be performed. Furthermore, even when L is 
relatively large (several tens to several hundreds), a search 
processing is not excessively delayed. A similarity search range 
such as "inner product of 0.6 or more" can be designated. 
Additionally, a similar vector search using the inner product as a 
similarity measure is effectively possible. 

Moreover, according to a fourth aspect of the present 
invention, there are provided a similar vector searching method and 
apparatus comprising: means for calculating a partial query 
condition; means for preparing a search object range; means for 
searching an index; means for calculating a square distance 
difference upper limit; and means for determining a similarity 



search result. An accumulated value of a partial square distance 
difference is calculated and used as a clue to the similarity 
search. Thereby, even when the vector is of several hundreds of 
dimensions, a high-speed search is possible with respect to the 
vector database. The similarity search of the type such that "most 
similar L vectors are obtained" can be performed. Furthermore, 
even when L is relatively large (several tens to several hundreds), 
the search processing is not excessively delayed. The similarity 
search range such as "inner product of 0-8 or less" can be 
designated. Additionally, the similar vector search using a 
distance as the similarity measure is effectively possible. 

BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a block diagram showing a whole constitution of 
a vector index preparing apparatus in a first embodiment, 

FIG. 2 is a block diagram showing the whole constitution 
of the vector index preparing apparatus in a second embodiment, 

FIG. 3 is a block diagram showing the whole constitution 
of a similar vector searching apparatus in a third embodiment, 

FIG. 4 is a block diagram shewing the whole constitution 
of the similar vector searching apparatus in a fourth embodiment, 

FIGS. 5A and 5B constitute integrally a flowchart showing 
a preparing procedure of a first step of vector index preparation 
in the first and second embodiments, 

FIGS 6A and 6B constitute integrally a flowchart showing 
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the preparing procedure of second and third steps of the vector 
index preparation in the first onbodiment, 

FIGS. 7A and 7B constitute integrally a flowchart showing 
the preparing procedure of the second and third steps of the vector 
index preparation in the second embodiment, 

FIGS. 8A and 8B constitute integrally a flowchart showing 
a search procedure of a first step of a similar vector search in 
the third embodiment, 

FIG. 9 is a flowchart showing the searching procedure of 
a second step of the similar vector search in the third embodiment, 

FIGS. 10A and 10B constitute integrally a flowchart 
showing the searching procedure of the first step for the similar 
vector search in the fourth anbodiment, 

FIGS 11A and 11B constitute integrally a flowchart 
15 showing the searching procedure of the second step of the similar 
vector search in the fourth embodiment, 

FIGS 12A and 12B constitute integrally a list showing a 
content example of a vector database in the first, second, third 
and fourth embodiments, 
20 FIG. 13 is a characteristic diagram showing a norm 

distribution tabulation result example in the first and second 
embodiments, 

FIG. 14 is a characteristic diagram showing a declination 
distribution tabulation result example in the first and second 
25 embodiments, 
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FIGS. 15A and 15B constitute integrally a list showing 
the content example of a norm division table in the first, second, 
third and fourth embodiments, 

FIG. 16 is a list showing the content example of a 
5 declination division table in the first, second, third and fourth 
embodiments, 

FIGS. 17A and 17B constitute integrally a list showing a 
content example (part) of a table W in the third embodiment, and 

FIGS 18A, 18B and 18C constitute integrally a list 
10 showing the content example (part) of the table W in the fourth 
embodiment. 

BEST MODE FOR CARRYING OUT THE INVENTION 
<First Embodiments 
15 A first embodiment of the present invention will be 

described hereinafter with reference to the drawings, 

(Constitution of Vector Index Preparing Apparatus ) 
FIG, 1 is a block diagram showing a whole constitution of 
20 the first embodiment of a vector index preparing apparatus 
according to claims 1, 3 to 8, 14, 16 to 21 of the present 
invention. In FIG, 1, a vector database 101 stores 200 , 000 pieces 
of vector data constituted of two items of: a 296-dimensional unit 
real vector prepared from a newspaper article full text database of 
25 200,000 collected newspaper articles and indicating characteristic 
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of each newspaper article; and an identification number in a range 
of 1 to 200,000, and has a content as shown in FIGS. 12A and 12B. 

Partial vector calculation means 102 calculates 37 types 
of 8-dimensional partial vectors v 0 to and a partial space 
5 number b of 0 to 36 with respect to a 2 96-dimens ional vector V of 
each vector data in the vector database 101. 

Norm distribution tabulation means 103 calculates 
Euclidean norm of the respective 37 partial vectors calculated by 
the partial vector calculation means 102 for 200,000 pieces of 
10 vector data, tabulates a distribution, and determines a norm 
division as a range of 256 continuous real numbers: 

Norm division 0 = [0, rl). 

Norm division 1 = [rl, r2), 

15 Norm division 255 = [r255, r256) 

A norm division table 104 stores a norm division 
calculated by the norm distribution tabulation means 103. 

Region number calculation means 105 normalizes the 8- 
dimensional vector whose component is any one of {0, 1, -1} and 
20 which is not 0 vector to obtain a norm of 1 with respect to each 8- 
dimensional partial vector v calculated by the partial vector 
calculation means 102. 

Region center vector 0 = (0, 0, 0, 0, 0, 0, 0, 1), 
region center vector 1 = (0, 0, 0, 0, 0, 0, 0, -1), 
25 region center vector 2 = (0, 0, 0, 0, 0, 0, 1, 0), 
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region center vector 3 = sqrt(l/2)*(0, 0, 0, 0, 0, 0, 1, 

1)/ 

region center vector 4 = sqrt(l/2 )*(0, 0, 0, 0, 0, 0, 1, 

-1), 

5 region center vector 5 = (0, 0, 0, 0, 0, 0, -1, 0), 

region center vector 6554 ~ sqrt( l/7)*(-l, -1, -1, -1, -1, 
-1/ 1, 0), 

region center vector 6555 = sqrt(l/8)*(-l, -1, -1, -1, -l f 
10 -1, 1, 1), 

region center vector 6556 = sqrt(l/8)*(-l, -1, -1, -1, -1, 

-1, 1/ -l)r 

region center vector 6557 = sqrt( l/7)*(-l, -1, -1, -1, -1, 
-1, «lr 0), 

15 region center vector 6558 = sqrt(l/8)*(-l, -1, -1, -1, -1, 

~1, -1, 1), 

region center vector 6559 - sqrt<l/8)*(-l, -1, -1, -1, -1, 
-1, -1, -1). 

The aforementioned 6560 vectors (additionally, "sqrt(x) indicates a 
20 square root of x") are obtained as region center vectors, a region 
center vector p d whose inner product with the partial vector v is 
largest is obtained, number d is used as a region number of a 
belonging region of v, and cosine of an angle formed by p.j and v is 
obtained as a declination c. 
25 Declination distribution tabulation means 106 tabulates a 
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distribution of a declination value c calculated by the region 
number calculation means 105 for 37 partial vectors of 200,000 
pieces of vector data, and determines a declination division as a 
range of four continuous real numbers: 
5 declination division 0 = [cO, cl), 

declination division 1 - [cl, c2), 

declination division 2 = [c2, c3), 

declination division 3 = [c3 , c4 ) . 

A declination division table 107 stores the declination 
10 division calculated by the declination distribution tabulation 
means 106. 

Norm division number calculation means 108 searches the 
norm division table 104 to determine a norm division number r to 
which the norm of each partial vector calculated by the partial 
15 vector calculation means 102 belongs. 

Declination division number calculation means 109 
searches the declination division table 107 to determine a 
declination division number c to which declinations of v and p 
belong f rem each partial vector v calculated by the partial vector 
20 calculation means 102 and the region center vector p calculated by 
the region number calculation means 105 for v. 

Index data calculation means 110 prepares the following 
key for search from a partial vector V b and partial space number b 
calculated by the partial vector calculation means 102, region 
25 number d calculated by the region number calculation means 105, 
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declination division number c calculated by the declination 
division number calculation means 109, and norm division number r 
calculated by the norm division number calculation means 108: 

K = ((b*65604d)*4+c)*256+r, 
5 and calculates a set (K, i, v b ) of the key K, identification number 
i of the partial vector and component v b as index data. 

Index constituting means 111 uses a key K from the index 
data (K, i, v b ) calculated by the index data calculation means 110, 
and constitutes an index in which a search tree for searching (i f 
10 v b ) , an inverse search table with a second key 

L = (d*4+c)*256+r 
stored therein from the region number d, declination division 
number c and norm division number r with respect to a set of each 
identification number i and each partial space number b, norm 
15 division table 104 and declination division table 107 are stored. 

A vector index 112 stores the search tree, inverse search 
table, norm division table 104 and declination division table 107 
prepared by the index constituting means 111, 



20 (Operation of Vector Index Preparing Apparatus ) 

Operation of the vector index preparing apparatus 
constituted as described above will be described with reference to 
the drawings* FIGS, 5A and 5B constitute integrally a flowchart 
showing a preparing processing procedure of a norm division table R 

25 and declination division table C in a first step of preparing the 
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vector index, and FIGS. . 6A, 6B constitute integrally a flowchart 
showing the processing procedure of calculating index registration 
data and preparing the vector index in second and third steps of 
preparing the vector index. In the drawings , "sqrt(x)" denotes the 
5 square root of x, "int(x)" denotes an integer portion of x, and 
"abs(x)" denotes an absolute value of x, respectively. Jtoreover, 
"sign2(x)" is a function taking a value of 1 when x is not negative, 
and a value of 2 when x is negative. 

10 (First Step of Vector Index Preparation) 

in a first step of vector index preparation, first the 
partial vector calculation means 102 reads the vector data in order 
from the vector database 101 and calculates the partial vector. 
The norm distribution tabulation means 103 and declination 

15 distribution tabulation means 106 calculate a norm distribution and 
declination distribution of the partial vector, respectively. At 
the time all the vector data is processed, the norm division table 
and declination division table are prepared. It is assumed that a 
norm upper limit value of the vector in the vector database is 

20 known and the upper value is r_sup. In an example of the present 
embodiment, since the vector of each vector data is a unit vector, 
r sup = 1 is clearly obtained. When the upper limit value of the 
norm of the vector in the vector database is unknown, inspection 
may be performed beforehand to obtain r_sup. 

25 First, in step 1001, tables Hr and He for tabulation are 
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initialized to 0, and total partial vector number n is also set to 
0. Subsequently, in step 1002, one piece of unprocessed vector 
data (i, v) is read from the vector database. The partial space 
number b is initialized to 0. In step 1003, 8~dimensional partial 
5 vector u is divided eight continuous components from a top of a 
read 296-dimensional vector v and 37 types are prepared in 
accordance with the value of b- For example, with first vector 
data of FIG. 12A, the partial vector of b = 0 is as follows. 
(+0.029259 -0.016005 -0.021118 +0.024992 -0.006860 -0.009032 - 
10 0.007255 -0.007715). 

The partial vector of b = 1 is as follows. 

(-0.025648 +0.016061 -0.060584 -0.013593 -0.020985 -0.112403 - 
0.012045 +0.044741) 

The partial vector of b = 36 is as follows. 
15 (+0.069379 +0.020206 +0.032996 +0.047815 +0.046106 +0.001794 
+0.035342 -0.003895) 

Subsequently, norm |u| of u is divided by the norm maximum value 
r_sup, multiplied by 10000, converted to an integer and accumulated 
in a corresponding division j of a norm distribution tabulation 

20 table Hr. A norm distribution is tabulated. 

FIG. 13 shows an example of a graph of the norm 
distribution tabulated in this manner. The abscissa of the graph 
indicates the division number of the norm distribution tabulation 
table Hr, and the ordinate indicates a value of Hr[ j] for each 

25 division number j, that is, the number of partial vectors having 
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norms in a norm range of the division j . With the partial vector 
of b - 0 of the first vector data of FIG. 12A, 

|u| « sqrt( 0.029259*0. 029259 + 0.016005*0.016005 + ... + 
0.007715*0.007715) = 0.049193, 
5 r__sup = 1, and the division j results in 

j = int((0. 049193/1. 0)*10000) = 491. 

The declination division is tabulated in steps 1004 to 
1009- First in the step 1004, component numbers are stored in 
order from a largest absolute value for eight components u[0] to 

10 u[7] of the partial vector u. With the partial vector of b = 0 of 
the first vector data of FIG. 12A f since the absolute value of a 0 
component is largest, the absolute value of a third component is 
next largest, and the absolute value of a fourth component is 
smallest, the following results: 

15 s[0..7] =(03215764). 

Subsequently, steps 1005 to 1008 are repeated eight times 
(8 = dimensions of partial space) by changing a value of a variable 
m from 0 to 7, and a number d of a vector having a largest inner 
product with the partial vector u among 6560 region center vectors, 

20 and a value x of the inner product are obtained. In the step 1005, 
a number j of the region center vector whose m+l 1 * component from 
the largest absolute value is *1 (code of the partial vector 
component) and remaining 7-m components are 0, and value y of the 
inner product multiplied by sqrt(m) are obtained. In the step 1006, 

25 the inner product is calculated from the value y obtained in the 
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step 1005 by y*sqrt(l/m) , and compared with the maximum value x of 
the inner product. When the inner product is larger than x, in the 
step 1007 the inner product maximum value x, and the region center 
vector number d are updated. A region center vector group whose 
5 component is any one of {+1, 0, -1} is used in this manner. 

Therefore, the numbers of the partial vector and region center 
vector having the largest inner product, and the value of the inner 
product can efficiently be obtained by very simple calculation* 

With the partial vector of b = 0 of the first vector data 

10 of FIG* 12A, the following results* 
( |u[0] | )*sqrt(l/l) =0.029259 
(|u[0]| + |u[3]|)*sgrt(l/2) = 0.038361 
( |u[0] | + |u[3]| + |u[2]| )*sqrt(l/3) = 0.043514 
(|u[0]| + |u[3]| + |u[2]| + |u[l]|)*sqrt(l/4) = 0.045687 

15 ( |u[0] | + |u[3] | + |u[2] | + |u[l] | + |u[5] | )*sqrt(l/5) = 0.044903 

<|u[0]| + |u[3]| + |u[2]| + |u[l]| + |u[5]|+|u[7]|)*sqrt(l/6) = 0.044140 
<|u[0]| + |u[3l| + |u[2]| + |u[l]| + |u[5]|+|u[7]| + |u[6]|)*sqrt(l/7) = 
0.043608 

(|u[0]| + |u[3]| + |u[2]| + |u[l]| + |u[5]| + |u[7]| + |u[6]| + |u[4]|)*sqrt(l/8) 
20 = 0.043217 

The maximum value x = 0.045687 of the inner product, and number d = 
(3 A 7)+2*(3"6)+2*(3"5)+(3 A 4) = 4212 of region center vector (+1/2,- 
1/2, -1/2, +1/2, 0,0, 0,0) are obtained. 

Subsequently in the step 1009 the inner product x is 
25 divided by the norm of the partial vector u, and cosine of the 



angle formed by the partial vector and region center vector is 
obtained, multiplied by 10000, converted into an integer, and 
accumulated in the corresponding division j of a declination 
distribution tabulation table He, so that the declination 
5 distribution is tabulated* FIG* 14 is an example of a graph of the 
declination distribution tabulated in this manner. The abscissa of 
the graph indicates the division number of the declination 
distribution tabulation table He, and the ordinates indicates a 
value of Hc[j] for each division number j, that is, the number of 

10 partial vectors having declinations in a declination range of the 
division j. Additionally in FIG. 14, since tabulated values of He 
of a division smaller than 8274 are all 0, only a division portion 
of 8000 to 10000 is shown- With the partial vector of b = 0 of the 
first vector data of FIG. 12A, the following results: 

15 j = int<10000*0. 045687/0. 049193) 

= into (10000*0.928730) = 9287 

After a variable b for selecting the partial vector, and 
a variable n for tabulating a total partial vector number are 
increased, it is judged in step 1010 whether or not all partial 

20 vectors of the noted vector data are processed. When the 

unprocessed partial vector remains, the flow returns to the step 
1003 to process the next partial vector. When all the partial 
vectors are processed, it is judged in step 1011 whether or not all 
the vector data in the vector database 101 is processed. When the 

25 unprocessed vector data remains, the flow returns to the step 1002 
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to process the next vector data. When all the vector data is read 
and processed, the flow advances to steps 1012 to 1018 to prepare 
the norm division table and declination division table. 

In the step 1012 an operation variable is initialized, 
5 and in the steps 1013 to 1018 a processing is performed to prepare 
division data of the norm division table and declination division 
table. In the step 1013, a total value x of the number of partial 
fg vectors having norms of 0 to r_sup*j/10000 in norm tabulation 

12 results, and a total value y of the number of partial vectors 

ifj 10 having declinations of 0 to j/10000 in declination tabulation 
Q results are obtained. 

Q It is judged in the step 1014 whether or not a ratio x/n 

fy of the number of the partial vectors having norms of 0 to 

Q r_sup*j/10000 to the total partial vector number is larger than a 

15 ratio of k/256 of the number of divisions to a k-th division among 
256 divisions of the norm division table. When the ratio is larger, 
the flow advances to step 1015 to set a boundary value R[k] of the 
k-th division of the norm division table to rjsup*j/10000. FIGS. . 
15A, 15B constitute integrally an example of the norm division 
20 table prepared from the norm distribution tabulation table Hr of 
the norm distribution of FIG. 13 as described above. It is seen 
that a division of 0.1 to 0.2 with the distribution concentrated 
therein is finely divided. 

In steps 1016 and 1017, for the declination division, a 
25 boundary value of an m-th division of the declination division 
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table is similarly determined. It is judged in step 1018 whether 
or not all norm tabulation results and declination tabulation 
results are processed. When an unprocessed tabulation result 
remains, the flow returns to the step 1013 to continue the 
5 processing. When all the tabulation results are completely 

processed, the flow advances to step 1019 to obtain R[0..256] and 
C[0..4] as the norm division table and declination division table, 
respectively, thereby ending the first step of the vector index 
preparation. FIG. 16 shows an example of the declination division 
10 table prepared from the declination distribution tabulation table 
He of the declination distribution of FIG. 14 as described above. 
It is seen that the vicinity of 0.95 with the distribution 
concentrated therein is finely divided. 

15 (Second Step of Vector Index Preparation) 

In a second step of vector index preparation, the 

processing described in steps 1101 to 1109 is performed, and index 

registration data is prepared from individual partial vectors. 

First, in the step 1101, the search tree T is initialized, and the 
20 number of pieces of T registration data is set to 0. For the 

search tree, 

1) An integer value can be used as a key to register 
vector data (i, u), that is, a set of an integer and eight floating 
point numbers. 

25 2) A range of integer values during registration can be 
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used as the key to search the registered data. 

As long as the above two conditions are satisfied, (equilibrium) 
search trees such as B tree and binary search tree described in 
textbooks such as "Algorithm No. 2 Search/Character 
5 String/Calculation Geography" authored by R. Segiwick, translated 
by Kohei Ndshita et al. and published by Kindai Kagaku K.K. (1992) 
and "Algorithm and Data Structure Handbook" authored by G. H. 
Gonnet, translated by Mitsuo Gen et al- and published by Keigaku 
Shuppan (1987) can be used. 

10 In the step 1102, one piece of vector data is read from 

the vector database 101, the partial space number b is increased in 
order from 0 and the partial vector of each partial space is 
processed. In the step 1103, the partial vector u is prepared, the 
prepared norm division table 104 is searched, and the number r of 

15 the norm division for the norm |u| is obtained. In the steps 1104 
to 1108, the same processing as that of the steps 1004 to 1008 of 
FIGS. . 5A, 5B is performed, the number d of the vector having the 
largest inner product with the partial vector u among 6560 region 
center vectors and the value x of the inner product are obtained. 

20 In the step 1109, the prepared declination division table 

107 is searched, and the number c of the declination division for 
declination (i.e., cosine of the angle formed by the partial vector 
and region center vector of the belonging region) x/|u| is obtained. 
In the step 1110, the index data calculation means 110 converts 

25 four integer values of the partial space number b, region number d, 
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declination division number c, and norm division number r to one 
integer value from the norm division number d and declination 
division number c obtained as described above, and calculates the 
key k during registration into the search tree by the following 
5 equation. 

k = b*^*It*l^*N c *1^4c*N r +r 
= b*7617440-fd*1024+c*256+r 
In step 1111 the calculation means calculates the index 
registration data (k, i, u) from the key k and partial vector data 

10 (i, u) . Additionally, denotes a total region number of 6560, ^ 
denotes a declination division number of 4, and N r denotes a norm 
division number of 256. In this manner, in the second step of the 
vector index preparation, the index registration data (k, i, u) for 
each partial vector of each vector data can efficiently be prepared 

15 (in a time proportional to the vector data number) . 



(Third Step of Vector Index Preparation ) 
In a third step of the vector index preparation, a 
processing described in steps 1111 to 1115 of FIG. SB is performed 
20 to prepare the vector index from the index registration data. 

First in the step 1111, k in the index registration data (k, i, u) 
is used as the key to (add) register data (i, u) into the search 
tree. Next in the step 1112, the key k is stored in element K[i, 
u] corresponding to the partial space number b of the vector data 
25 of the identification number i of an inverse search table K. After 
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increasing the partial space number b by 1, it is judged in the 
step 1113 whether or not the processing of all partial spaces is 
finished. When the unprocessed partial space remains, the flow 
returns to the step 1103 to process the next partial vector- When 
5 the processing of all the partial spaces is finished, the flow 

advances to the step 1114* It is judged in the step 1114 whether 
or not all the vector data in the vector database 101 is processed. 
When the unprocessed vector data remains, the flow returns to the 
step 1102 to process the next vector data. When the processing of 

10 all the vector data is finished, the flow advances to the step 1115 
to prepare the vector index with the search tree T, inverse search 
table K, norm division table R, and declination division table C 
stored therein f thereby completing the vector index preparation. 
As described above, according to the vector index 

15 preparing method and apparatus of the first embodiment of the 
present invention, the following superior effects are produced. 

1) The 296-dimensional vector is decomposed into 37 
types of 8-dimensional partial vectors, a vector direction is 
precisely quantized with a set of the region number of the 

20 belonging region out of 6560 regions and the declination division 
number for the respective partial vectors, a vector size is 
quantized with the norm division number, a plurality of keys are 
encoded to obtain one integer value and the value is registered in 
the search tree, so that a high-speed high-precision range search 

25 is enabled for each partial space. 
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2) Moreover, since the inverse search table is 
prepared/disposed, a function of designating the identification 
number of the vector data and obtaining the vector component can be 
realized without doubling the component data. Therefore, the 

5 original vector database 101 becomes unnecessary during searching, 
and a storage capacity of the searching apparatus can be reduced. 

3 ) In the norm division tabulation means and declination 
distribution tabulation means, a division boundary is determined in 
such a manner that the number of partial vectors belonging to each 

10 division is set to be as uniform as possible. Therefore, even with 
the vector database having a deviation in the distribution, an 
optimum vector index (with a minimized reduction of search speed) 
can constantly be prepared. 

4) A vector set whose component is any one of {0, +1, - 
15 1} and which is obtajuried by normalizing all vectors excluding 0 

vector is used as the region center vector. Therefore, the 
belonging region of each partial vector can be calculated without 
depending on the region number. An amount of calculations such as 
the calculation of the absolute value order of the partial vector 
20 component, and the addition of component absolute values is 

remarkably small- Therefore, even with a large-scaled vector 
database constituted of several tens to several hundreds of pieces 
of vector data, the vector index can be prepared in a practical 
processing time. 

25 



<Second Embodiments 

A second embodiment of the present invention will next be 
described with reference to the drawings, 

(Constitution of vector Index Preparing Apparatus) 

FIG. 2 is a block diagram showing the whole constitution 
of the second embodiment of the vector index preparing apparatus 
according to claims 2, 3 to 8, 15, 16 to 21 of the present 
invention- In FIG. 2, a vector database 201 stores 200,000 pieces 
of vector data constituted of three items of; the 296-d±mensional 
unit real vector prepared from the newspaper article full text 
database of 200,000 collected newspaper articles and indicating the 
characteristic of each newspaper article; the identification number 
of 1 to 200,000; and an article subtitle, and has a content as 
shown in FIGS. . 12A, 12B. 

Partial vector calculation means 202 calculates 37 types 
of 8-dimensional partial vectors v 0 to v 36 and the partial space 
number b of 0 to 36 with respect to the 296-dimensional vector V of 
each vector data in the vector database 201. 

Norm distribution tabulation means 203 calculates 
Euclidean norm of the respective 37 partial vectors calculated by 
the partial vector calculation means 202 for 200,000 pieces of 
vector data, tabulates the distribution, and determines the norm 
division as the range of 256 contiguous real numbers: 

Norm division 0 = [0, rl), 
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Norm division 1 = [rl, r2) f 
Norm division 255 = [r255, r256) 

A norm division table 204 stores the norm division 
5 calculated by the norm distribution tabulation means 203. 

Region number calculation means 205 normalizes the 8- 
dimensional vector whose component is any one of {0, 1, -1} and 
which is not 0 vector to obtain a norm of 1 with respect to each 8- 
dimensional partial vector v calculated by the partial vector 
10 calculation means 202. 
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region center vector 6557 = sqrt(l/7)*(-l, -1, -1, -l, -1, 
-1, -lr 0), 

region center vector 6558 = sqrt(l/8)*(-l, -1, -1, -1, -1, 
-1, -1, 1), 

5 region center vector 6559 = sqrt(l/8)*(-l, -1, -1, -1, -1, 

-lr -1, -1). 

The aforementioned 6560 vectors (additionally, "sqrt(x) indicates a 
square root of x") are obtained as the region center vectors , the 
region center vector p d whose inner product with the partial vector 
10 v is largest is obtained, number d is used as the region number of 
the belonging region of v, and cosine of the angle formed by p 3 and 
v is obtained as the declination c. 

Declination distribution tabulation means 206 tabulates 
the distribution of the declination value c calculated by the 
15 region number calculation means 205 for 37 partial vectors of 
200,000 pieces of vector data, and determines the declination 
division as the range of four continuous real numbers: 
declination division 0 = [cO, cl), 
declination division 1 = [cl , c2), 
20 declination division 2 = [c2, c3), 

declination division 3 = [c3, c4). 

A declination division table 207 stores the declination 
division calculated by the declination distribution tabulation 
means 206. 

25 Norm division number calculation means 208 searches the 



norm division table 204 to determine the norm division number r to 
which the norm of each partial vector calculated by the partial 
vector calculation means 202 belongs. 

Declination division number calculation means 209 
5 searches the declination division table 207 to determine the 

declination division number c to which declinations of v and p 
belong from each partial vector v calculated by the partial vector 
calculation means 202 and the region center vector p calculated by 
the region number calculation means 205 for v. 

10 index data calculation means 210 prepares the following 

key for search from the partial vector V b and partial space number 
b calculated by the partial vector calculation means 202, region 
number d calculated by the region number calculation means 205 , 
declination division number c calculated by the declination 

15 division number calculation means 209, and norm division number r 
calculated by the norm division number calculation means 208: 

K = ((b*656CHd)*4+c)*256+r, 
and calculates a set (K, i, y) of the key K, identification number 
i of the partial vector and component division number y j as the 

20 index data. 

Index constituting means 211 uses the key K from the 
index data (K, i, y) calculated by the index data calculation means 
210, and constitutes an index in which the search tree for 
searching (i, y), the inverse search table with the second key 

25 L = <d*4+c)*256+r 
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stored therein from the region number d, declination division 
number c and norm division number r with respect to the set of each 
identification number i and each partial space number b, norm 
division table 204 and declination division table 207 are stored. 
5 A vector index 212 stores the search tree, inverse search 

table, norm division table 204 and declination division table 207 
prepared by the index constituting means 211. Additionally, the 
y constituting elements 201 to 212 correspond to the constituting 

U elements 101 to 112 of FIG. 1, and particularly the constituting 

10 elements 201 to 209 are the same as the constituting elements 101 
Q to 109 of FIG. 1. 

Q Component division number calculation means 213 

fU calculates component division numbers y 0 to y 7 in a range of 0 to 

1.JL 

□ 255 from the partial vector v b calculated by the partial vector 

15 calculation means 202, norm division number calculated by the norm 
division number calculation means 208, and each component value of 
the partial vector - 

(Operation of Vector Index Preparing Apparatus) 
20 (First Step of Vector Index Preparation) 

The operation of the vector index preparing apparatus 
constituted as described above will be described with reference to 
the drawings. The procedure of the preparation processing of the 
norm division table R and declination division table C in a first 
25 step of the vector index preparation is the same as the procedure 
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in the first embodiment. With the same vector database, the 
contents of the prepared norm division table R and declination 
division table C are both the same as the contents of the norm 
division table R and declination division table C in the first 
5 embodiment, and the description thereof is therefore omitted. 

(Second, Third Steps of Vector Index Preparation) 
FIGS* 7A and 7B constitute integrally a flowchart showing 
the processing procedure of index registration data calculation and 

10 vector index preparation in second and third steps of the vector 
index preparation. Steps 1200 to 1216 of FIGS. 7A and 7B 
correspond to the steps 1100 to 1116 of FIGS. 6A and 6B, 
particularly the respective steps other than the steps 1211, 1215, 
1217 are the same in processing as the corresponding steps of FIGS. 

15 6A and 6B, and the description thereof is therefore omitted. 

In the step 1217, a component division number y[0..7] for 
each component of u is calculated from partial vector u[0..7]. 
Since abs(u[m] )s|u|<R[iM-l] for any u[m], the following is 
established. 

20 -1 < u[m]/R[r+l] < +1 

The component division number y[m] is an integer value of 0 to 255, 
which can be represented by eight bits. In the step 1211, y is 
used instead of u, and k is used as the key to register integer 
data (i, y) in the search tree T. Since each y[m] can be 

25 represented by eight bits, the capacity of the search tree T is 
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remarkably reduced as compared with when u[m] is registered in the 
form of a floating point. In the step 1215, since the vector index 
including the search tree T prepared in this manner is prepared, 
the capacity of the resulting and prepared vector index can be 
5 small as compared with when u[m] is registered. 

Additionally, in the second embodiment, each component 
u[m] is approximated with the 8-bit integer value y[m] in the step 
1217. However, when a precision becomes insufficient with eight 
bits during similarity searching, the data may be represented and 

10 registered by 9 to 24 bits to obtain a sufficient precision. 

As described above, according to the vector index 
preparing method and apparatus of the second embodiment of the 
present invention, the following superior effects are produced. 

1) The 296-dimensional vector is decomposed into 37 

15 types of 8-dimensional partial vectors, the vector direction is 
precisely quantized with a set of the region number of the 
belonging region out of 6560 regions and the declination division 
number for the respective partial vectors, the vector size is 
quantized with the norm division number, and additionally each 

20 coamponent of the partial vector is quantized based on the norm 

division such as the component division number. The plurality of 
keys are encoded to obtain one integer value and the value is 
registered in the search tree together with the component division 
number of the partial vector as an approximation result, so that 

25 the high-speed high-precision range search is enabled for each 
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partial space, 

2) Moreover, since the inverse search table is 
prepared/disposed, the function of designating the identification 
number of the vector data and obtaining the vector component can be 

5 realized without doubly disposing the component data. Therefore, 
the original vector database 101 becomes unnecessary during 
searching, and the storage capacity of the searching apparatus can 
be reduced. 

3) in the norm division tabulation means and declination 
10 distribution tabulation means, the division boundary is determined 

in such a manner that the number of partial vectors belonging to 
each division is set to be as uniform as possible. Therefore, even 
with the vector database having a deviation in the distribution, 
the optimum vector index (with a minimized reduction of the search 
15 speed) can constantly be prepared. 

4) The vector set whose component is any one of {0, +1, 
-1} and which is obtained by normalizing all the vectors excluding 
0 vector is used as the region center vector. Therefore, the 
belonging region of each partial vector can be calculated without 

20 depending on the region number. The amount of calculations such as 
the calculation of the absolute value order of the partial vector 
component , and the addition of component absolute values is 
remarkably small. Therefore, even with the large-scaled vector 
database constituted of several tens to several hundreds of pieces 

25 of vector data, the vector index can be prepared in the practical 
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processing time- 

5) The capacity of the vector index to be prepared can 
remarkably be reduced, 

5 <Third Embodiments 

A third embodiment of the present invention will next be 
described with reference to the drawings. 

(Constitution of Similar Vector Searching Apparatus) 

10 FIG. 3 is a block diagram showing the whole constitution 

of a similar vector searching apparatus according to claims 9, 11, 
12, 22, 24, 25 of the present invention. In FIG. 3, a vector index 
301 is prepared by the vector index preparing apparatus of the 
aforementioned first OTbodiment, and is a vector index prepared 

15 from the vector database which stores 200,000 pieces of vector data 
constituted of tro items of: the 296-dimensional real vector 
prepared from the newspaper article full text database of 200 , 000 
collected newspaper articles and indicating the characteristic of 
each newspaper article; and the identification number of 1 to 

20 200,000 for uniquely identifying each article and which has the 
content as shown in FIG, 12A, 12B. 

In order to perform similarity search on the newspaper 
article full text database, search condition input means 302 inputs 
the identification number of any article in the newspaper article 

25 full text database, and a similarity lower limit value and maximum 
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obtained pieces number of 0 to 100 indicating a similarity search 
range, searches the vector index 301 with the identification number 
to obtain a vector of the corresponding article as a query vector Q 
from the inputted identification number, and obtains an inner 
5 product lower limit value a from the similarity lower limit value. 

Partial query condition calculation means 303 calculates 
a partial inner product lower limit value f as a lower limit value 
of an inner product of 37 types of 8-dimensional partial query 
vectors q with the partial vector corresponding to q by f = 

10 a |g| 2 /|Q| 2 with respect to partial spaces of 0 to 36 for the query 
vector Q obtained by the search condition input means 302. 

Search object range generation means 304 enumerates all 
sets (d, c, [r ir r 2 ]) of the region number d for specifying a region 
including a partial document vector whose partial inner product 

15 with the partial query vector q is possibly larger than the partial 
inner product lower limit value f , declination division number c, 
and norm division range [r lf r 2 ] frcra the partial query vector q and 
partial inner product lower limit value f obtained by the partial 
query condition calculation means 303 for the partial space b and 

20 the norm division table and declination division table in the 
vector index 301. 

Index search means 305 calculates search condition K for 
the vector index 301 from (d, c f [r^ r 2 ]) generated by the search 
object range generation means 304 for each partial space b 

25 similarly as calculation of the key during vector index preparation 
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as follows. 

« b*7617440+d*1024+c*256+r 1 
= b*7617440+d*1024+c*256+r 2 
5 The index search means then searches the range of the vector index 
301 with the search condition K and obtains all sets (i, v) of 
partial vector v and identification number i having a key to match 
the search condition. 

Inner product difference upper limit calculation means 
10 306 calculates a partial inner product difference value t from the 
set (i, v) of the partial vector v and identification number i 
obtained by the index search means 305 and the partial query vector 
q and partial inner product lower limit value f obtained by the 
partial query condition calculation means 303 by t = (v*q)-f , and 
15 accumulates (adds) the partial inner product difference value t to 
a table element S[i] having the identification number i as an affix. 
Thereby, the upper limit value of the inner product difference is 
calculated by subtracting the inner product lower limit value a 
from an inner product Q # V of the vector V of the vector data of the 
20 identification number i and query vector Q. 

An inner product difference table 307 accumulates the 
upper limit value of the inner product difference calculated by the 
inner product difference upper limit calculation means 306 , and 
refers to/stores an inner product difference value S[i] of the 
25 vector data of the identification number i- 
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Similarity search result determination means 308 searches 
the vector index 301 with the identification number i in order from 
a positive large inner product difference upper limit value S[i] in 
the elanent S[i] of the inner product difference table 307 to 
5 obtain the corresponding vector V, calculates an inner product 

difference value V*Q-a by subtracting the inner product lower limit 
value a calculated by the search condition input means 302 from 
the inner product V»Q of V with the query vector Q calculated by 
the search condition input means 302 r and replaces S[i] with the 

10 inner product difference value V«Q-<x. The number of articles which 
have the inner product difference values larger than the maximum 
value of the partial inner product difference accumulated value of 
the article having the inner product difference value not 
calculated, and whose inner product difference is calculated 

15 reaches L or more. At this time, or at the time the inner product 
difference values of all the articles having positive partial inner 
product difference accumulated values are calculated, for L result 
candidates at maximum (i, S[i]) having positive and large inner 
product difference values, a set (i, S[i]+a) of the identification 

20 number i and inner product S[i]+a is outputted as a search result 
to search result output means 309. 

The search result output means 309 calculates and 
displays a similarity of the identification numbers of L newspaper 
articles at maximum to a range of 0 to 100 as a result of the 

25 similar vector search from the search result obtained by the 
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similarity search result determination means 308. 

(Operation of Similar Vector Searching Apparatus ) 
Operation of the similar vector searching apparatus 
5 constituted as described above will be described with reference to 
the drawings* FIG. 8A, 8B constitute integrally a flowchart 
showing a search processing procedure in a first step of similar 
vector search, and FIG. 9 is a flowchart showing the search 
processing procedure in a second step of the similar vector search. 

10 In the first step of the similar vector search, the partial query 

vector q and partial inner product lower limit value f are prepared 
from the search condition inputted from the search condition input 
means 302, and the vector index 301 is searched. The inner product 
difference upper limit value S[i] of each vector data, that is, a 

15 value obtained by subtracting the inner product lower limit value 
from the inner product with the query vector is obtained such that 
the value is less than S[i] in the inner product difference table 
307* Subsequently, in a second step of the similar vector search, 
the inner product difference upper limit value obtained in the 

20 inner product difference table 307 in the first step is used as a 
clue. The similarity search result determination means 308 
searches the vector component and obtains the inner product 
difference in order from the vector data which meets a search 
condition "the inner product with the query vector is larger than 

25 a" and whose inner product with the query vector is relatively 
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large. The determination means continues its processing until a 
designated number of (i.e. , L) or more pieces of vector data 
guaranteed to be larger in inner product difference value than any 
vector data having the inner product difference not obtained yet 
5 are collected, or until the inner product difference values of all 
the vector data meeting the search condition are obtained. The 
inner product is calculated from the obtained inner product 
difference value and a final result is output ted. 

10 (First Step of Similar Vector Search) 

A content of the similar vector search will be described 
hereinafter with reference to FIGS. 8A and 8B and FIG. 9 by means 
of an example in which an identification number 1, similarity lower 
limit value 90, and maximum obtained pieces number 10 are inputted 

15 as search conditions. Since the identification number is 1, the 

respective components of the 2 9 6-dimens ional vector are obtained as 
shown in FIG- 12A. First in step 1301, 200,000 elements S[0] to 
S[ 200000] of an inner product difference table s are 
initialized/set to 0. Subsequently, the aforementioned search 

20 conditions are read from the search condition input means 302, and 
stored in i, Z, L, respectively* 

After the partial space number b is initialized to 0 in 
step 1302, the inner product lower limit value a is calculated 
from a similarity lower limit value z. This search condition 

25 results in a ( 90-50 )/50 = 0.8. In steps 1304, 1305, for each 
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partial space, an inversion table K of the vector index 301 is used 
to obtain the key, the search table is searched to obtain the 
vector data, a vector portion of the data with the identification 
number of 1 is stored in Q, and thereby the query vector is 
5 obtained in Q[0. .295] „ After the partial space number is 

initialized in step 1306, the vector index is searched with respect 
to each partial space in steps 1307 to 1317 and the inner product 
difference upper limit value of each vector data is obtained in the 
inner product difference table 307. 

10 In step 1307, partial query vector q[0..7] and partial 

inner product lower limit value f of the partial space number b are 
obtained, that is, the lower limit value of the inner product of 
the partial space partial vector data and q is obtained. With b = 
0, |q| 2 = 0.221795, |Q| 2 - 1, then the following results. 

15 f = 0.8*0.221795/1.0 = 0.177436 

After the region number d is initialized to indicate 0, a table W 
for use in determining a search object range is prepared. When the 
table W is referred to with the declination division number c and 
norm division number r, and inner product p # q of a center vector p 

20 of the noted region with the region number d with the partial query 
vector q is less than W[c, r], the table is prepared in such a 
manner that the inner product of the partial vector v and partial 
query vector q of divisions (d, c, 0) to (d, c, r) is f or less. 
In this case, the partial vector of divisions (d, c, 0) to <d, c, 

25 r) does not satisfy the search condition (i.e., the partial inner 
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product is larger than f ) for the partial space, the search of 
these divisions can be omitted. 

In order to obtain the table W, with the partial v 
closest to the partial query vector q in the region d, a case may 
5 be considered in which p, q, v are on one plane and angle co formed 
by v and q is smallest in a range of declination division c. in 
this case, assuming that an angle formed by p and q is 8 and that a 
maximum value of an angle formed by p and v is the angle co 
formed by v and q is co = G-<j>, and the following relations are 
10 therefore used. 

f < vq = |v|*|q|*cos(9-<|>) < 
R[ r+1 ] * | q | * ( oos0*cos^+sin9sijKt> ) 
C[c] = cos<(> 

cos6 = (p*q)/|p|*|q| = (P*q)/|q| 
15 From the above, the following inequality satisfied by p-q is solved, 
and formula W[c, r] of step 1307 is obtained. 

f < R[r+l]*C[c]*(p»q)+R[r+l]*sqrt(l-C[c] 2 )*sqrt(|q| 2 - 

(P*q) 2 )) 

In this manner, a value of table W[c, r] can be 
20 determined only from norm |q| of the partial query vector without 
referring to actual components of partial vector v or depending on 
the region d. In the present embodiment, since the norm division 
table R and declination division table C are as shown in FIGS. 15A, 
15B and 16, with b = 0, the table W has a content as shown in FIGS. 
25 17A and 17B. In the drawings, for an elonent with a table value of 
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" 9, 99999", the norm is too small for the partial query vector q, 
and the inner product of even the partial vector v of any direction 
with q cannot reach f . This means that this norm division cannot 
be a search object. It is seen from FIGS. 17A and 17B that with c 
5 =0, that is, a large declination value, a broad range search is 
performed and that with c = 3, that is, a small declination value, 
only a portion with a large norm, that is, a narrower range is 
searched. 

In step 1308, the inner product t of the center vector p 

10 of the noted region with the partial query vector q is obtained, 
and a loop variable c for declination division is initialized to 
indicate 0. Subsequently, it is checked in step 1309 whether or 
not the inner product t is smaller than that of element W[0, 255] 
indicating the minimum value of the table W. When the inner 

15 product is smaller, it is defined that any partial vector using the 
region d as part of the key does not satisfy the search condition. 
Therefore, the flow jumps to step 1312. If not so, in step 1310 
for the declination division c, a minimum value r of the norm 
division to be searched is obtained with the aid of the table W 

20 calculated in the step 1307. A search range [kmin, kmax] of the 
vector index 301 is obtained from this r, partial space number b, 
region number d, and declination division number c. In step 1311, 
this search range [kmin, kmax] is used as the key to search a range 
of the search tree, and the partial inner product difference value 

25 is calculated by subtracting the partial inner product lower limit 
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value f from the inner product of the partial query vectors q and v 
for respective sets ( j, v) of the identification number j and 
vector v included in a range search result, and is accumulated in 
the corresponding element S[ j] of the inner product difference 
5 table 307, 

For example, with b = 0, d = 4212, 

q = (+0.029259 -0.016005 -0-021118 +0.024992 -0.006860 - 
0.009032 -0-007255 -0.007715), and 

p 0 = (+1/2, -1/2, -1/2, +1/2, 0, 0, 0, 0), 
10 then the following results: 

t = p-q = +0.045687. 
Since t is larger than W[0, 255] = -0.02527, the flow advances to 
step 1310. From the table W of FIGS. 17A and 17B, for the norm 
division number r in: 
15 W[0, r] as t < W[0, r+1], 

r = 1. With c = 0, the key of the search tree is as follows; 

[kmin, kmax] = [0*6717440+4212*1024+0*256+1, 
0*6717440+4212*1024+0*256+255] = [4313089, 4313343] 
Since the partial vector with b = 0 of the vector data with the 
20 identification number 1, that is, 

v = (+0.029259 -0.016005 -0.021118 +0-024992 -0.006860 - 
0.009032 -0.007255 -0.007715) is registered with the key k = 
0*6717440+4212*1024+0*256+1 = 4313089, the vector is one of the 
range search results. The partial inner product difference value 
25 is: 
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(vq)-f = 0*221795-0.177436 = 0-044359. 
Then, S[l] = 0.044359. 

Moreover, the partial vector with b = 0 of the vector 
data with identification number 2 r that is, 
5 v = (+0.029259 -0.016005 -0.021118 +0.024992 -0.006860 - 

0.009032 -0.007255 -0.007715) is registered with the key k = 
0*6717440+619*1024+2*256+2, and is included in the results of the 
range search with b = 0, c = 2, d = 619. The partial inner product 
difference value is: 

10 (vq)-f = 0.00005. 

Then, S[2] = 0-00005. 

similarly, with b = 1, the partial vector of the vector 
data with the identification number 2 is registered with the key k 
= 1*6717440+2691*1024+1*256+93, and is included in the results of 

15 the range search with b = l, c = l, d = 2691. For the partial 
inner product difference value, 

(vq)-f = 0.00217 
is accumulated in S[2], and S[2] - 0.00222. 

In this manner, in steps 1312, 1313, while c is increased, 

20 the search range determination and search processing, and the 

calculation and accumulation of the inner product difference are 
performed for each declination division. Subsequently, in steps 
1314 and 1315 while the region number d is successively increased 
to 6560, each region is subjected to a processing of steps 1308 to 

25 1313. Furthermore, in steps 1316 and 1317 while the partial space 
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number is successively increased to 37, each partial space is 
subjected to a processing of steps 1307 to 1315 , and the first step 
of the similar vector search is finished. In this stage, in the 
inner product difference table 307, for the vector data V with each 
5 identification number/ a difference between the inner product V»Q 
with the query vector Q and the inner product lower limit value a, 
that is, an estimated value upper limit of inner product difference 
value (V*Q)-a is obtained. Because in the respective partial 
spaces b, for the partial vector whose inner product with the 

10 partial query vector q is larger than the partial inner product 

lower limit value f , the partial inner product difference value is 
obtained without exception. Therefore, the partial inner product 
difference value of the vector data whose partial inner product 
difference value is not obtained must indicate a negative value. 

15 This negative value is replaced with 0 and accumulated ("inner 
product difference table is not changed" is equivalent to 
accumulation of 0), and therefore the accumulation result of the 
partial inner product difference value is one of the inner product 
difference upper limit values which press the inner product 

20 difference value from above. After the inner product difference 
table 307 is obtained as described above, a second step of the 
similar vector search is executed, and the final search result is 
obtained. 



25 



(Second Step of Similar Vector Search) 
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A processing procedure of the second step will next be 
described with reference to a flowchart of FIG. 9. In step 1401 
the number of candidates satisfying the search conditions of the 
present time is cleared to indicate 0, and a flag A[0* • 200000] 
5 indicating whether or not the inner product difference of the 

vector data is obtained is initialized/set to 0, that is, "no inner 
product difference is obtained". Moreover, the minimum value (= 
threshold value) t of the inner product difference value among the 
candidates satisfying the search conditions at the present time is 

10 initialized to indicate 0. 

It is checked in step 1402 whether there is non-inspected 
vector data, that is, vector data with the inner product difference 
thereof non-obtained. When the inner product differences of all 
the vector data are obtained, the flow jumps to step 1412- 

15 Additionally, when the inner product lower limit value given as the 
search condition is 0 or more, and when a deviation in the 
distribution of the respective components of the vector data is 
small, condition indicates "no" in the step 1404 far before 
obtaining the inner product differences of all the vector data. 

20 Therefore, "no" does not result from the step 1402 under usual 
search conditions. 

In step 1403 obtained is the identification number j of 
the vector data in which A[j] is 0, that is, value S[ j] of the 
inner product difference table is maximized in the non-inspected 

25 vector data. The processing of this step can efficiently be 
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executed by arranging the inner product difference table 307 in a 
descending order of the inner product difference value or by 
representing the table by data structures such as heap. 

In step 1404, the previously obtained t is compared with 
5 S[j]. If S[j] is t or less, it is defined that no vector data 

exceeding the inner product difference values of n candidates of 
the present time exists in the non-inspected vector data. 
Therefore, the flow jumps to step 1412 to calculate the result from 
the candidates of the present time, and finish the search 

10 processing, When t is larger than S[j], in the step 1405 the flag 
A[ j] of the noted vector data is changed to 1, it is recorded "the 
inner product difference is obtained" , and the vector index 301 is 
searched to obtain the vector V with the identification number j. 
Moreover, the inner product difference value (V*Q)-cc with the query 

15 vector V is obtained, and the upper limit value in the 

corresponding element S[j] of the inner product difference table 
207 is replaced with a correct inner product difference value. 
When there is an allowance in the storage region, the inner product 
difference table may be recorded in a new table without being 

20 replaced. 

In step 1406, the replaced S[j] is again compared with t. 
When S[j] is larger than t, steps 1407 to 1414 are executed and the 
vector data with the identification number j is added to the 
candidates. It is judged in the step 1407 whether L candidates are 
25 already obtained at this time. When the Ii candidates are not 
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obtained, the number n of candidates is increased in the step 1408. 
In the step 1409, after j is registered as the final candidate 
(candidate lowest in inner product difference among the candidates) 
of arrangement B of the candidate identification numbers, B[0..n-1] 
5 is arranged in the descending order of S[B[k] ] . When the candidate 
number n reaches L in the step 1410, the threshold value t is 
updated in the step 1411, and the flow returns to the step 1402 to 
continue the processing. 

If judgment is "no" in the step 1402 or 1404, the flow 

10 goes out of the aforementioned loop and advances to step 1412. In 
the step 1412, the inner product value is obtained by adding a to 
the already obtained inner product difference value S[B[k]] with 
respect to each of n (L at maximum) candidate identification 
numbers B[0] to B[n-1]. For each k of 0 to n-1, a set (B[k], 

15 S[B[k]]) of a result number B[k] of the vector data having k-th 
large inner product, and the value S[B[k] ] of the inner product 
with the query vector V is outputted as the final result of the 
similar vector search, and the similar vector search is finished. 

When the value of the inner product lower limit in the 

20 search conditions is 0.5 or more and sufficiently large, there is 
no large deviation in the vector data distribution, and the number 
of pieces of vector data having the inner product not less than the 
inner product lower limit a is sufficiently larger than the 
obtained pieces number L, the loop of the steps 1402 to 1411 is 

25 repeated about several times the obtained pieces number L. In this 
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case, the judgment of the step 1404 is "no", the number of pieces 
of vector data for actually searching the vector to obtain the 
inner product is very small, and it is possible to efficiently 
obtain the final result. Additionally, this characteristic is 
5 established even when L indicates about several hundreds. 

Therefore, in the search conditions with a relatively large L, a 
processing efficiency is remarkably enhanced as compared with a 
conventional similar vector searching method in which a practical 
search speed can be obtained only with L indicating several pieces 
10 at most. 

As described above, according to the similar vector 
searching method and apparatus of the third embodiment of the 
present invention, for the vector database of a large number of 
pieces of collected vector data with the vector of several hundreds 

15 of dimensions, a high-speed similarity search of the type "most 
similar L pieces of vector data are obtained" is possible. 
Furthermore, even when L is relatively large (several tens to 
several hundreds), the search processing is not excessively delayed. 
A similarity search range such as "inner product value of 0.8 or 

20 more" can be designated. There can be provided superior similar 
vector searching method and apparatus in which the vector inner 
product is used as a similarity measure. 

Additionally, in the third embodiment, the case in which 
the vector index prepared by the vector index preparing apparatus 

25 of the first embodiment of the present invention is searched has 



IP: 
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been described. However, when the processing for obtaining each 
partial vector is only changed so as to obtain each component value 
from the norm division number and each component division number in 
the index preparing apparatus of the first embodiment^ the similar 
5 vector searching apparatus of the third embodiment can also be used 
to search the vector index prepared by the vector index preparing 
apparatus of the second embodiment. Furthermore, effects similar 
to the aforementioned effects can be expected. 

Furthermore, in the third embodiment, a procedure for 

10 successively performing the search processing on each partial space 
b in the first step of the similar vector search has been described. 
However, for the loop of steps 1306 to 1317 of the flowchart of 
FIGS. 8A and 8B, with a parallel computer having a large number of 
central processing units (CPUs), the processing is divided and 

15 processed by the respective CPUs, and intermediate results are 

accumulated in a common inner product difference table. In this 
case, the processing can easily be performed in parallel with a 
high parallelism, and the search speed can further be enhanced. 

20 <Fourth Embodiments 

A fourth embodiment will next be described with reference 
to the drawings. 



25 



(Constitution of Similar Vector Searching Apparatus) 
FIG. 4 is a block diagram showing the whole constitution 
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of the similar vector searching apparatus according to claims 10, 
11, 13, 23, 24, 26 of the present invention. In FIG. 4, a vector 
index 401 is prepared by the vector index preparing apparatus of 
the aforementioned first embodiment, and is a vector index prepared 
5 from the vector database which stores 200,000 pieces of vector data 
constituted of two items of: the 296-dimensional real vector 
prepared from the newspaper article full text database of 200,000 
collected newspaper articles and indicating the characteristic of 
each newspaper article; and the identification number of 1 to 

10 200,000 for uniquely identifying each article and which has the 
content as shown in FIGS. 12A and 12B. 

In order to perform the similarity search on the 
newspaper article full text database, search condition input means 
402 inputs the identification number of any article in the 

15 newspaper article full text database, and the similarity lower 
limit value and maximum obtained pieces number of 0 to 100 
indicating the similarity search range, searches the vector index 
401 with the identification number to obtain the vector of the 
corresponding article as the query vector Q from the inputted 

20 identification number, and obtains a square distance from the 

similarity lower limit value, that is, obtains a square distance 
upper limit value a 2 as the upper limit value of the squared 
distance. 

Partial query condition calculation means 403 calculates 
25 a partial square distance upper limit value f 2 as the upper limit 
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value of the square distance of 37 types of 8 -dimensional partial 
query vectors q and the partial vector corresponding to q by f 2 = 
a2 N| 2 /|Q| a with respect to partial spaces of 0 to 36 for the query 
vector Q obtained by the search condition input means 402. 
5 Search object range generation means 404 enumerates all 

sets (d, c r [r jr r 2 ]) of the region number d for specifying a region 
including a partial vector whose partial square distance with the 
partial query vector q is possibly smaller than the partial square 
distance upper limit value f 2 , declination division number c, and 
10 norm division range [r t , r 2 ] from the partial query vector q and 
partial square distance upper limit value f 2 obtained by the 
partial query condition calculation means 403 for the partial space 
b and the norm division table and declination division table in the 
vector index 401. 

15 Index search means 405 calculates the search condition K 

for the vector index 401 from (d, c, [r lf r 2 ]) generated by the 
search object range generation means 404 for each partial space b 
similarly as calculation of the key during the vector index 
preparation as follows. 

20 K = [lw K«] 

k^ - b*7617440+d*1024+c*256+r x 
k^ = b*7617440+d*1024+c*256+r 2 
The index search means then searches the range of the vector index 
401 with the search condition K and obtains all sets (i, v) of the 

25 partial vector v and identification number i having the key to 
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match the search condition. 

Square distance difference upper limit calculation means 
406 calculates a partial square distance difference value t frcm 
the set (i, v) of the partial vector v and identification number i 
5 obtained by the index search means 405 and the partial query vector 
q and partial square distance upper limit value f 2 obtained by the 
partial query condition calculation means 403 by t = f 2 |v-q| 2 , and 
accumulates (adds) the partial square distance difference value t 
to the table element S[i] having the identification number i as the 

10 affix. Thereby, the upper limit value of the square distance 

difference is calculated by subtracting a square distance |V-Q| 2 of 
the vector V of the vector data of the identification number i and 
the query vector Q frcm a square distance upper limit value a 2 . 

A square distance difference table 407 accumulates the 

15 upper limit value of the square distance difference calculated by 
the square distance difference upper limit calculation means 406, 
and refers to/stores a square distance difference value S[i] of the 
vector data of the identification number i. 

Similarity search result determination means 408 searches 

20 the vector index 401 with the identification number i in order frcm 
a positive large square distance difference upper limit value S[i] 
in the element S[i] of the square distance difference table 407 to 
obtain the corresponding vector V, calculates a square distance 
difference value a 2 -|V-Q| 2 by subtracting the square distance |v-Q| 2 

25 of V and query vector Q calculated by the search condition input 
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means 402 from the square distance upper limit value a 2 calculated 
by the search condition input means 402, and replaces S[i] with the 
square distance difference value a 2 -|v-Q| 2 . The number of articles 
which have the square distance difference values larger than the 
5 maximum value of the partial square distance difference accumulated 
value of the article having the square distance difference value 
not calculated and whose square distance difference value is 
calculated reaches L or more. At this time, or at the time the 
square distance difference values of all the articles having 

10 positive partial square distance difference accumulated values are 
calculated, for L result candidates at maximum (i, S[i]) having 
positive and large square distance difference values, a set (i, 
sqrt(ct 2 -S[i] ) ) of the identification number i and distance sqrt(cc 2 - 
S[i]) is outputted as a search result to search result output means. 

15 Search result output means 409 calculates and displays a 

similarity of the identification numbers of L newspaper articles at 
maximum to a range of 0 to 100 as a result of the similar vector 
search from the search result obtained by the similarity search 
result determination means 408. 

20 

(Operation of Similar Vector Searching Apparatus) 
Operation of the similar vector searching apparatus 
constituted as described above will be described with reference to 
the drawings- FIGS. 10A and 10B constitute integrally a flowchart 
25 showing a search processing procedure in a first step of similar 
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vector search, and FIGS. 11A and 11B constitute integrally a 
flowchart showing the search processing procedure in a second step 
of the similar vector search. In the first step of the similar 
vector search, the partial query vector q and partial square 
5 distance upper limit value f are prepared from the search condition 
inputted from the search condition input means 402, and the vector 
index 401 is searched. The square distance difference upper limit 
value S[i] of each vector data, that is, a value obtained by 
subtracting the square distance with the query vector frcra the 

10 square distance upper limit value is obtained such that the value 
is less than S[i] in the square distance difference table 407. 
Subsequently, in the second step of the similar vector search, the 
square distance difference upper limit value obtained in the square 
distance difference table 407 in the first step is used as a clue. 

15 The similarity search result determination means 408 searches the 
vector component and obtains the square distance difference in 
order from the vector data which meets a search condition "the 
square distance with the query vector is smaller than cc 2 " and whose 
square distance with the query vector is relatively small. The 

20 determination means continues its processing until a designated 

number of (i.e., L) or more pieces of vector data guaranteed to be 
larger in square distance difference value than any vector data 
having the square distance difference not obtained yet are 
collected, or until the square distance difference values of all 

25 the vector data meeting the search condition are obtained. A 
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distance is calculated from the obtained square distance difference 
value, and a final result is outputted. 

(First Step of Similar Vector Search) 
5 The content of the similar vector search will be 

described hereinafter with reference to FIGs . 10A, 10B, 11A and 11B 
by means of an example in which an identification number 1, 
similarity lower limit value 90, and maximum obtained pieces number 
10 are inputted as the search conditions. Since the identification 

10 number is 1, the respective components of the 296-dimensional 
vector are obtained as shown in FIG. 12A. First in step 1501 , 
200,000 elements S[0] to S[ 200000] of a square distance difference 
table S are initialized/set to 0. Subsequently, the aforementioned 
search conditions are read from the search condition input means 

15 402, and stored in i, Z, L, respectively. 

After the partial space number b is initialized to 0 in 
step 1502, the square distance upper limit value a 2 is calculated 
from the similarity lower limit value Z. This search condition 
results in a «- (100-90)750 = 0.2. In steps 1504, 1505, for each 

20 partial space, the inversion table K of the vector index 401 is 

used to obtain the key, the search table is searched to obtain the 
vector data, the vector portion of the data with the identification 
number of 1 is stored in Q, and thereby the query vector is 
obtained in Q[0..295]. After the partial space number is 

25 initialized in step 1506, the vector index is searched with respect 
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to each partial space in steps 1507 to 1517 and the square distance 
difference upper limit value of each vector data is obtained in the 
square distance difference table 407, 

In step 1507, partial query vector q[0. .7] and partial 
5 square distance upper limit value f 2 of the partial space number b 
are obtained, that is, the upper limit value of the partial square 
distance of the partial space partial vector data v and q is 
obtained. With b = 0, |q| 2 = 0.221795, |Q| 2 = 1, then the following 
results. 

10 f 2 = 0.04*0.221795/1.0 = 0.0088718 

After the region number d is initialized to indicate 0, the table W 
for use in determining the search object range is prepared. When 
the table W is referred to with the declination division number c 
and norm division number r, and the inner product p*q of the center 

15 vector p of the noted region with the region number d with the 

partial query vector q is less than W[c, r] , the table is prepared 
in such a manner that the partial square distance of the partial 
vector v and partial query vector q of divisions (d, c, 0) to (d, c, 
r) is f 2 or more. In this case, the partial vector of divisions (d, 

20 c, 0) to (d, c, r) does not satisfy the search condition (i.e., the 
partial square distance is larger than f 2 ) for the partial space, 
the search of these divisions can be omitted. 

In order to obtain the table W, with the partial v 
closest to the partial query vector q in the region d, the case may 

25 be considered in which p, q, v are on one plane and angle o> formed 



by v and q is smallest in the range of declination division c. In 
this case, assuming that the angle formed by p and q is 6 and that 
the maxiinum value of the angle formed by p and v is (j>, the angle a> 
formed by v and q is o = 0-<j>, and the following relations are 
therefore used. 

f 2 > |v-q| 2 = |v| 2 +|q| 2 -2*|v|*|q|*cos(0H>) > R[r] 2 +|q| 2 - 
2*R[r+l ] * | q | * (cos9*cos(t>+sinesin(t) ) 
C[c] = cos<|> 

cosG = (p*q)/|p|*|q| = (p*q)/|q| 
From the above, the following inequality satisfied by p*q is solved, 
and formula W[c, r] of step 1507 is obtained. 

f 2 < R[r] 2 +|q| 2 -2*R[r+l]*((p*q)*C[c]+sqrt(|q| 2 - 
(P*q) 2 )*sqrt(l-C[c] 2 >) 

In this manner, the value of the table W[c, r] can be 
determined only from the norm |q| of the partial query vector 
without referring to the actual components of partial vector v or 
depending on the region d. In the present embodiment, since the 
norm division table R and declination division table C are as shown 
in FIGS. 15A, 15B and 16, with b = 0, b = 1, the table w has a 
content as shown in FIGS. 18A, 18B and 18C. Similarly as FIGS. 17A 
and 17B, the drawings mean that for the element with the table 
value of "9.99999", the norm division is not a search object for 
the partial query vector q. Moreover, with b = 0 the table values 
of divisions 10 to 255 are not described- With b = 1 the table 
values of divisions 0 to 59 and 180 to 255 are not described. 
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Because all these parts have the value "9,9999" and the value is 
therefore omitted. In this case, since the distance is used as the 
similarity measure, even with too small, or conversely too large 
norm, the distance from the partial query vector is enlarged. As a 
5 result, the search condition "the distance is less than a" cannot 
be satisfied. 

In step 1508, the inner product t of the region center 
vector p of the noted region with the partial query vector q is 
obtained, and the loop variable c for declination division is 

10 initialized to indicate 0. Subsequently, it is checked in step 
1509 whether or not the inner product t is smaller than that of 
element Min(W[0, r] indicating the minimum value of the table W. 
When the inner product is smaller, it is defined that any partial 
vector using the region d as part of the key does not satisfy the 

15 search condition. Therefore, the flow jumps to step 1512, If not 
so, in step 1510 for the declination division c, a minimum value 
and maximum value r^ of the norm division to be searched are 
obtained as the division of the norm division number r, in which 
W[c, r] is established, with the aid of the table W calculated in 

20 the step 1507. A search range [kmin, kmax] of the vector index 401 
is obtained from this [r^, r^] , partial space number b, region 
number d, and declination division number c. 

In step 1511, this search range [kmin, kmax] is used as 
the key to search the range of the search tree, and the partial 

25 square distance difference value is calculated by subtracting the 
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partial square distance |v-q| 2 of the partial query vectors q and v 
from the partial square distance upper limit value f 2 for 
respective sets ( j, v) of the identification number j and vector v 
included in the range search result, and is accumulated in the 
5 corresponding element S[j] of the square distance difference table 
407. 

For example, with b = 0, d = 4212, 

q = (+0.029259 -0.016005 -0,021118 +0.024992 -0.006860 - 
0.009032 -0.007255 -0.007715), and 
10 p = (+1/2, -1/2, -1/2, +1/2, 0, 0, 0, 0), 

then the following results : 

t = p»q = +0.045687. 
Since t is larger than Min(W[0, r] ) = 0.03356, the flow advances to 
step 1510. From the table W of FIGS. 15A and 15B, for exan^>le, 
15 with c = 0, 

^nrin ~ If ^hbx = 5 . 

The search range of the search tree is as follows: 

[kmin, kmax] = [0*6717440+4212*1024+0*256+1, 
0*6717440+4212*1024+0*256+255] = [4313089, 4313093]. 
20 Since the partial vector x with b = 0 of the vector data with the 
identification number 1 is 

x = (+0.029259 -0.016005 -0.021118 +0.024992 -0.006860 - 
0.009032 -0.007255 -0.007715), 

and is registered with k = 0*6717440+4212*1024+0*256+1 = 4313089, 
25 the vector is one of the range search results. The partial square 
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distance difference value is: 

f 2 -|v-nq| 2 = 0.0088718-0 = 0.0088718. 
Then, S[l] = 0.0088718. 

In this manner, in steps 1512, 1513, while c is increased, 
5 the search range determination and search processing, and the 

calculation and accumulation of the square distance difference are 
performed for each declination division. Subsequently, in steps 
1514 and 1515 while the region number d is successively increased 
to 6560, each region is subjected to a processing of steps 1508 to 

10 1513. Furthermore, in steps 1516 and 1517 while the partial space 
number is successively increased to 37, each partial space is 
subjected to a processing of steps 1507 to 1515, and the first step 
of the similar vector search is finished. In this stage, in the 
square distance difference table 407, for the vector data V with 

15 each identification number, an upper limit of an estimated value of 
a square distance difference value <x 2 -|v-Q| 2 as a difference 
between the square distance upper limit value a 2 and the square 
distance |v-Q| 2 with the query vector Q is obtained. Because in 
the respective partial spaces b, for the partial vector whose 

20 square distance with the partial query vector q is smaller than the 
partial square distance upper limit value f 2 , the partial square 
distance difference value is obtained without exception. Therefore, 
the partial square distance difference value of the vector data 
whose partial square distance difference value is not obtained must 

25 indicate a negative value. This negative value is replaced with 0 
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and accumulated ("the square distance difference table is not 
changed" is equivalent to accumulation of 0), and therefore the 
accumulation result of the partial square distance difference value 
is one of the square distance difference upper limit values which 
5 press the square distance difference value from above. After the 

square distance difference table 407 is obtained as described above, 
a second step of the similar vector search is executed, and the 
final search result is obtained. 

10 (Second Step of Similar Vector Search) 

A processing procedure of the second step will next be 
described with reference to the flowchart of FIGS* 11A and 11B. In 
step 1601 the number of candidates satisfying the search conditions 
of the present time is cleared to indicate 0, and a flag 

15 A[0. .200000] indicating whether or not the square distance 

difference of the vector data is obtained is initialized/set to 0, 
that is, "no square distance difference is obtained". Moreover, 
the minimum value {= threshold value) t of the square distance 
difference value among the candidates satisfying the search 

20 conditions at the present time is initialized to indicate 0. 

It is checked in step 1602 whether there is non-inspected 
vector data, that is, vector data with the non-obtained square 
distance difference. When the square distance differences of all 
the vector data are obtained, the flow jumps to step 1612. 

25 Additionally, when the square distance upper limit value given as 



the search condition is 1 or less, and when a deviation in the 
distribution of the respective components of the vector data is 
small/ condition indicates "no" in the step 1604 far before 
obtaining the square distance differences of all the vector data. 
Therefore, "no" does not result from the step 1602 under the usual 
search conditions. In step 1603 obtained is the identification 
number j of the vector data in which A[ j] is 0, that is, value S[ j] 
of the square distance difference table is maximized in the non- 
inspected vector data. The processing of this step can efficiently 
be executed by arranging the square distance difference table 407 
in the descending order of the square distance difference value or 
by representing the table by data structures such as heap. 

In step 1604, the previously obtained t is compared with 
S[j]. If S[j] is t or less, it is defined that no vector data 
exceeding the square distance difference values of n candidates of 
the present time exists in the non-inspected vector data. 
Therefore, the flow jumps to step 1612 to calculate the result from 
the candidates of the present time, and finish the search 
processing • 

When t is larger than S[j], in the step 1605 the flag 
A[ j] of the noted vector data is changed to 1, it is recorded "the 
square distance difference is obtained", and the vector index 401 
is searched to obtain the vector V with the identification number j. 
Moreover, the square distance difference value a. 2 - | V-Q | 2 with the 
query vector V is obtained, and the upper limit value in the 
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corresponding element S[ j] of the square distance difference table 
407 is replaced with a correct square distance difference value. 
When there is an allowance in the storage region, the square 
distance difference table may be recorded in a new table without 
5 being replaced. In step 1606, the replaced S[ j ] is again compared 
with t. When S[j] is larger than t, steps 1607 to 1611 are 
executed and the vector data with the identification number j is 
added to the candidates. 

It is judged in the step 1607 whether L candidates are 

10 already obtained at this time- When the L candidates are not 

obtained, the number n of candidates is increased in the step 1608. 
In the step 1609, after j is registered as the final candidate 
(candidate lowest in square distance difference among the 
candidates) of arrangement B of the candidate identification 

15 numbers, B[0..n-1] is arranged in the descending order of S[B[k] ] - 
When the candidate number n reaches L in the step 1610, the 
threshold value t is updated in the step 1611, and the flow returns 
to the step 1602 to continue the processing. If judgment is "no" 
in the step 1602 or 1604, the flow goes out of the aforementioned 

20 loop and advances to step 1612. 

In the step 1612, the distance with the query vector Q is 
obtained from the already obtained square distance difference value 
S[B[k]] by sqrt(a 2 -S[B[k]]) with respect to each of n (L at 
maximum) candidate identification numbers B[0] to B[n-1]. For each 

25 k of 0 to n-1, a set (B[k], S[B[k]]) of a result number B[k] of the 
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vector data having k-th small distance, and the value S[B[k]] of 
the distance with the query vector Q is outputted as the final 
result of the similar vector search, and the similar vector search 
is finished. 

5 When the value of the square distance upper limit a. 2 in 

the search conditions is 0.5 or less and sufficiently small, there 
is no large deviation in the vector data distribution, and the 
number of pieces of vector data having the square distance less 
than the square distance upper limit a 2 is sufficiently larger than 

10 the obtained pieces number L, the loop of the steps 1602 to 1611 is 
repeated about several times the obtained pieces number L. In this 
case, the judgment of the step 1604 is "no", the number of pieces 
of vector data for actually searching the vector to obtain the 
square distance is very small, and it is possible to efficiently 

15 obtain the final result. Additionally, this characteristic is 
established even when L indicates about several hundreds. 
Therefore, in the search conditions with a relatively large L, the 
processing efficiency is remarkably enhanced as compared with the 
conventional similar vector searching method in which the practical 

20 search speed can be obtained only with L indicating several pieces 
at most- 

As described above, according to the similar vector 
searching method of the fourth embodiment of the present invention, 
for the vector database of a large number of pieces of collected 
25 vector data with the vector of several hundreds of dimensions, the 
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high-speed similarity search of the type "Host similar L pieces of 
vector data are obtained" is possible* Furthermore, even when L is 
relatively large (several tens to several hundreds), the search 
processing is not excessively delayed. The similarity search range 
5 such as "distance value of 0.2 or less" can be designated. There 
can be provided the superior similar vector searching method in 
which the distance between the vectors is used as the similarity 
measure. 

Additionally, in the fourth embodiment, the case in which 

10 the vector index prepared by the vector index preparing apparatus 
of the first onbodiment of the present invention is searched has 
been described. However, when the processing for obtaining each 
partial vector is only changed so as to obtain each component value 
from the norm division number and each component division number in 

15 the index preparing apparatus of the first embodiment, the similar 
vector searching apparatus of the fourth embodiment can also be 
used to search the vector index prepared by the vector index 
preparing apparatus of the second embodiment. Furthermore, the 
effects similar to the aforementioned effects can be expected. 

20 Moreover, in the fourth embodiment, a mode in which the 

query vector is not directly inputted, and the identification 
number of the vector data in the vector database is designated has 
been described. However, even when the query vector data is 
directly designated from the outside, the similar vector searching 

25 apparatus can easily be implemented in the similar method as 
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described above. 

Furthermore, in the fourth onbodiment, a procedure for 
successively performing the search processing on each partial space 
b in the first step of the similar vector search has been described. 
5 However, for the loop of steps 1506 to 1517 of the flowchart of 

FIGS. 10A and 10B, with the parallel computer having a large number 
of central processing units (CPUs), the processing is divided and 
processed by the respective CPUs, and the intermediate results are 
accumulated in the common inner product difference table, in this 
10 case, the processing can easily be performed in parallel with a 
high parallelism, and the search speed can further be enhanced. 

Possibility of Industrial Utilization 

As described above, according to the present invention, 

15 there is provided a vector index preparing method comprising: 
partial vector calculation means; norm distribution tabulation 
means; norm division table; region number calculation means; 
declination distribution tabulation means; declination division 
table; norm division number calculation means; declination division 

20 number calculation means; index data calculation means; and index 
constituting means. Thereby, even when a vector is of several 
hundreds of dimensions, a high-speed search is possible with 
respect to a vector database having unclear direction and norm 
distribution. During similarity searching, either one of two types 

25 of similarities of a distance between vectors and a vector inner 
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product can be selected. The similarity search of a type such that 
"most similar L vectors are obtained" can be performed. 
Furthermore, even when L is relatively large (several tens to 
several hundreds), a search processing is not excessively delayed. 
5 A similarity search range such as "inner product of 0.6 or more" 

can be designated. Additionally, a calculation amount required for 
index preparation is in a practical range. Such vector index can 
effectively be prepared. 

Moreover, when the vector index preparing method of the 

10 present invention further comprises component division number 

calculation means, in addition to the aforementioned effect, an 
effect is produced that a calculation error by quantization of a 
component is minimized and a capacity of the vector index to be 
prepared can remarkably be reduced. 

15 Furthermore, according to of the present invention, there 

is provided a similar vector searching method ccoiprisingr partial 
query condition calculation means; search object range generation 
means; index search means; inner product difference upper limit 
calculation means or square distance difference upper limit 

20 calculation means; and similarity search result determination means. 
An accumulated value of a partial inner product difference is 
calculated and used as a clue to a similarity search. Thereby, 
even when the vector is of several hundreds of dimensions, a high- 
speed search is possible with respect to a vector database. The 

25 similarity search of the type such that "roost similar I* vectors are 



obtained" can be performed. Furthermore, even when L is relatively 
large (several tens to several hundreds), a search processing is 
not excessively delayed- A similarity search range such as "inner 
product of 0.6 or more" can be designated. Additionally, a similar 
vector search using the inner product or a distance as a similarity 
measure is effectively enabled. Additionally, it is unnecessary to 
designate that the inner product or the distance be used as the 
similarity measure during the vector index preparation. A superior 
effect is therefore produced that single vector index can be used 
to selectively use the similarity measure as occasion demands 
during searching - 

Moreover, according to the present invention, there is 
provided a similar vector searching method comprising: means for 
calculating a partial query condition; means for generating a 
search object range; means for searching an index; means for 
calculating a square distance difference upper limit; and means for 
determining a similarity search result. An accumulated value of a 
partial square distance difference is calculated and used as a clue 
to the similarity search. Thereby, even when the vector is of 
several hundreds of dimensions, a high-speed search is possible 
with respect to the vector database. The similarity search of the 
type such that "most similar L vectors are obtained" can be 
performed. Furthermore, even when I* is relatively large (several 
tens to several hundreds), the search processing is not excessively 
delayed. The similarity search range such as "inner product of 0.8 
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or less" can be designated. Additionally, the similar vector 
search using a distance as the similarity measure is effectively 
enabled. 

When the vector data constituting an index preparation 
5 object or a search object is high-dimensional and is of several 

hundreds of dimensions, the number of pieces of vector data in the 
vector database is as large as several tens to several hundreds of 
pieces, and the number of obtained pieces during searching is as 
many as several tens of pieces, the effect of the present invention 

10 are particularly remarkable. In the conventional vector index 
preparing method, several hundreds of hours are required as an 
index preparation time, but the time can be reduced to several tens 
of minutes. Moreover, the similarity search processing, which has 
required several minutes or which has been impracticable in the 

15 conventional similar vector searching method, can be performed for 
one second or less. Such very large effects can practically be 
obtained. 



